તમારા CSS કુશળતાને ધ્યાનમાં રાખવામાં સહાય માટે ટિપ્સનો સંગ્રહ.
અન્ય મહાન યાદીઓ માટે તપાસો [@sindresorhus](https://github.com/sindresorhus/)’s ની યાદી અદ્ભુત યાદીઓ.
અરજી / અનપ્પેલી કરવા માટે * પ્રોપ્સ * આધાર * ફાળો માર્ગદર્શિકા
box-sizingF
:not() અરજી / અનપ્પેલી કરવા માટે નેવિગેશન પર
બોર્ડર્સ
line-height તરફ body
nth-child
max-height શુદ્ધ માટે CSS સ્લાઇડર્સનો
rem માટે વૈશ્વિક કદ બદલવાનું; વાપરવ
em માટે સ્થાનિક કદ બદલવાનું
:root માટે Flexible Type
font-size on ફોર્મ તત્વો માટે a બેટર મોબાઇલ અનુભવ
display: none તરીકે વપરાયેલ લાઇન બ્રેક્સ પર સેટ
કરો
સીએસએસ રીસેટ્સ સ્ટાઇલ ઘટકો માટે સ્વચ્છ સ્લેટ સાથે વિવિધ બ્રાઉઝર્સમાં સ્ટાઇલ સુસંગતતાને અમલમાં મૂકવા માટે મદદ કરે છે. તમે જેમ કે CSS રીસેટ લાઇબ્રેરીનો ઉપયોગ કરી શકો છો Normalize, et al., અથવા તમે વધુ સરળ રીસેટ અભિગમનો ઉપયોગ કરી શકો છો:
હવે તત્વો માર્જિન અને પેડિંગની છીનવી લેવામાં આવશે, અને
box-sizing તમે સીએસએસ બોક્સ મોડેલ સાથે લેઆઉટ મેનેજ કરી શકો
છો.
નોટ: જો તમે અનુસરશો તો
Inherit box-sizing નીચે ટીપ
તમે નીચેની શામેલ ન કરવાનું પસંદ કરી શકો છો box-sizing મિલકત
માં તમારા CSS રીસેટ .
box-sizing
પરવાનગી આપો box-sizing માંથી વારસામાં આવશે html:
આનાથી ફેરફાર કરવાનું સરળ બને છે box-sizing પ્લગઇન્સ અથવા અન્ય
ઘટકોમાં લીવરેજ કે અન્ય વર્તન.
તત્વના ગુણધર્મોને ફરીથી સેટ કરતી વખતે, પ્રત્યેક વ્યક્તિગત સંપત્તિને ફરીથી સેટ કરવું જરૂરી નથી:
button {
background: none;
border: none;
color: inherit;
font: inherit;
outline: none;
padding: 0;
}
તમે ‘બધા’ લઘુલિપિનો ઉપયોગ કરીને એક તત્વની તમામ ગુણધર્મોને સ્પષ્ટ કરી શકો
છો. અનસેટ માટે મૂલ્યને સેટ કરવાથી એક ઘટકના ગુણધર્મોને તેમની
પ્રારંભિક મૂલ્યોમાં બદલાય છે:
નોંધ: આઇ 11 માં all અનેઅનસેટ
શોર્ટહેન્ડ સપોર્ટેડ નથી.
:not() અરજી / અનપ્પેલી કરવા માટે નેવિગેશન પર બોર્ડર્સ
તેના બદલે નો મૂકવા સરહદ પર…
…અને પછી તે છેલ્લા તત્વ બોલ લેવા…
…વાપરવ :not() pseudo-class ફક્ત તમે ઇચ્છો તે તત્વો પર જ લાગુ
કરો:
CSS પસંદગીકાર સીમાને વ્યાખ્યાયિત કરે છે કે જે રીતે મનુષ્ય તેનું વર્ણન કરશે.
તમે તપાસ કરી શકો છો કે ફોન્ટ તેને દૂરસ્થ રીતે લાવવા પહેલાં સ્થાનિક રૂપે ઇન્સ્ટોલ કરેલું છે કે નહીં, તે પણ એક સારા પ્રદર્શનની મદદ છે.
@font-face {
font-family: "Dank Mono";
src:
/* Full name */
local("Dank Mono"),
/* Postscript name */
local("Dank Mono"),
/* Otherwise, download it! */
url("//...a.server/fonts/DankMono.woff");
}
code {
font-family: "Dank Mono", system-ui-monospace;
}
આ પ્રોટીપ અને ડેમો શેર કરવા માટે એડમ આર્ગીલેને ટોપીની મદદ.
line-height તરફ body
તમારે ઉમેરવાની જરૂર નથી line-height to દરેક
<p>, <h*>, et al. અલગ. તેની
જગ્યાએ, તેને ઉમેરવા body:
આ માર્ગ textual તત્વો શકવું બોલાવે થી body સરળતાથી.
દૃશ્યમાન કીબોર્ડ વપરાશકર્તાઓ પૃષ્ઠમાં કીબોર્ડ ઇવેન્ટ્સ ક્યાં જાય છે તે નિર્ધારિત કરવા પર ધ્યાન કેન્દ્રિત કરે છે. ફોર્મ ઘટકો માટે ધ્યાન કેન્દ્રિત કરો અને બ્રાઉઝરનું ડિફૉલ્ટ અમલીકરણ પછી સુસંગત રહો:
a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
box-shadow: none;
outline: #000 dotted 2px;
outline-offset: .05em;
}
ના, તે કાળા જાદુ નથી, તમે ખરેખર ઊભી તત્વોને કેન્દ્રિત કરી શકો છો:
```css html, body { height: 100%; margin: 0; }
body { -webkit-align-items: center; -ms-flex-align: center; align-items: center; display: -webkit-flex; display: flex; } `` …અને CSS ગ્રીડ સાથે પણ:
કેન્દ્ર માંગો છો કંઈક બીજું? વર્ટિકલ, આડા…કંઈપણ, કોઈપણ સમયે, ગમે ત્યાં? CSS-Tricks has a nice write-up on કરવાનું બધા કે.
નોટ: જુઓ કેટલાક માટે buggy behavior સાથે flexbox માં IE11.
સૂચિ આઇટમ્સ વાસ્તવિક, અલ્પવિરામથી વિભાજીત સૂચિની જેમ દેખાય છે તે બનાવો:
વાપરવ આ :not() pseudo-class તેથી છેલ્લી વસ્તુમાં કોઈ
અલ્પવિરામ ઉમેરવામાં આવી નથી.
નોટ: આ ટિપ સુલભતા માટે આદર્શ નથી, ખાસ કરીને સ્ક્રીન વાચકો. અને બ્રાઉઝરમાંથી કૉપિ / પેસ્ટ CSS- જનરેટેડ સામગ્રી સાથે કામ કરતું નથી. સાવધાની સાથે આગળ વધો.
nth-child
વાપરવ નકારાત્મક nth-child વસ્તુઓ પસંદ કરવા માટે CSS માં 1
દ્વારા n.
li {
display: none;
}
/* select items 1 through 3 and display them */
li:nth-child(-n+3) {
display: block;
}
અથવા, કારણ કે તમે પહેલેથી જ વિશે થોડું શીખ્યા છે
using :not(), પ્રયત્ન કરો:
/* select all items except the first 3 and display them */
li:not(:nth-child(-n+3)) {
display: none;
}
વેલ તે ખૂબ સરળ હતું.
ચિહ્નો માટે એસવીજીનો ઉપયોગ ન કરવા માટે કોઈ કારણ નથી
The SVG scale is good for all resolution types and it is supported in all browsers back to IE9. તેથી છુટકારો મેળવવા .png, .jpg, or .gif-jif-whatev ફાઈલો.
નોટ: જો તમારી પાસે SVG આઇકોન-માત્ર બટનો છે અને જોવામાં આવેલાં વપરાશકર્તાઓ માટે SVG લોડ કરવામાં નિષ્ફળ જાય, તો તે એક્સેસીબિલીટી જાળવી રાખવામાં મદદ કરશે.:
તેમાં વિચિત્ર નામ હોઈ શકે છે પરંતુ સાર્વત્રિક પસંદગીકારનો ઉપયોગ કરી શકો છો
(*) અડીન બહેન સિલેક્ટર સાથે (+) શક્તિશાળી CSS
ક્ષમતા પ્રદાન કરી શકે છે:
આ ઉદાહરણમાં, અન્ય ઘટકોને અનુસરતા દસ્તાવેજના પ્રવાહમાંના બધા તત્વો પ્રાપ્ત
થશે margin-top: 1.5em.
વધુ માટે “lobotomized owl” પસંદગીકાર, વાંચવું Heydon Pickering’s post on A List Apart.
max-height શુદ્ધ માટે CSS સ્લાઇડર્સન
ફક્ત ઉપયોગ કરીને CSS- ફક્ત સ્લાઇડર્સનો અમલ કરો
max-height ઓવરફ્લો છુપાયેલ સાથે:
.slider {
max-height: 200px;
overflow-y: hidden;
width: 300px;
}
.slider:hover {
max-height: 600px;
overflow-y: scroll;
}
આ તત્વ વિસ્તરે છે max-height Value on hover and slider
display as a result of overflow.
કોષ્ટકો સાથે કામ કરવા માટે પીડા હોઈ શકે છે જેથી આનો ઉપયોગ કરીને પ્રયાસ કરો
table-layout: fixed કોષો સમાન પહોળાઈ પર રાખો:
પેઇન-મુક્ત કોષ્ટક લેઆઉટ.
સ્તંભ ગટર સાથે કામ કરતી વખતે તમે છુટકારો મેળવી શકો છો nth-,
first-, અને last-child હેક્સ દ્વારા ઉપયોગ કરીને
flexbox’s space-between મિલકત:
હવે સ્તંભ ગટર હંમેશા સરખે ભાગે-અંતરે દેખાય છે.
લિંક્સ દર્શાવો જ્યારે <a> તત્વ કોઈ લખાણ કિંમત નથી પરંતુ
href લક્ષણ એક લિંક છે:
તે ખૂબ અનુકૂળ છે
માટે એક શૈલી ઉમેરો “default” લિંક્સ:
હવે લિંક્સ કે જે CMS દ્વારા દાખલ કરવામાં આવે છે, જે સામાન્ય રીતે એક નથી
class એટ્રિબ્યુટ, સામાન્ય રીતે કાસ્કેડને અસર કરતા વગર ભેદ
રાખશે.
સ્વભાવિક રેશિયો સાથે બૉક્સ બનાવવા માટે, તમારે ફક્ત ટોચ અથવા તળિયે ગાદીને DIV પર લાગુ કરવાની જરૂર છે:
.container {
height: 0;
padding-bottom: 20%;
position: relative;
}
.container div {
border: 2px dashed #ddd;
height: 100%;
left: 0;
position: absolute;
top: 0;
width: 100%;
}
પેડિંગ માટે 20% નો ઉપયોગ કરીને તેના પહોળાઈના 20% જેટલા બૉક્સની ઊંચાઇને બનાવે છે. કોઈ વ્યૂપોર્ટની પહોળાઇ, બાળક ડિવ તેના પાસા રેશિયો રાખશે (100% / 20% = 5:1).
તૂટેલી તસવીરો CSS ના થોડુંક સાથે વધુ સૌંદર્યલક્ષી-આનંદી બનાવો:
img {
display: block;
font-family: sans-serif;
font-weight: 300;
height: auto;
line-height: 2;
position: relative;
text-align: center;
width: 100%;
}
હવે ઉમેરો pseudo-elements તૂટેલી છબીના વપરાશકર્તા સંદેશ અને URL સંદર્ભને પ્રદર્શિત કરવાના નિયમો:
img::before {
content: "We're sorry, the image below is broken :(";
display: block;
margin-bottom: 10px;
}
img::after {
content: "(url: " attr(src) ")";
display: block;
font-size: 12px;
}
આ પેટર્ન માટે સ્ટાઇલ વિશે વધુ જાણો Ire Aderinokun’s original post.
rem માટે વૈશ્વિક કદ બદલવાનું; વાપરવ
em માટે સ્થાનિક કદ બદલવાનું
રુટ પર મૂળ ફોન્ટ માપ સુયોજિત કર્યા પછી (html { font-size: 100%; }), શાબ્દિક તત્વો માટે ફૉન્ટનું કદ સેટ કરો em:
પછી મોડ્યુલો માટે ફૉન્ટ-કદ સેટ કરો to rem:
હવે દરેક મોડ્યુલ શ્રેણીબદ્ધ અને સરળ, વધુ નિભાવવા યોગ્ય અને લવચીક બની જાય છે.
આ વૈવિધ્યપૂર્ણ વપરાશકર્તા સ્ટાઇલશીટ માટે એક મહાન યુક્તિ છે. એક વપરાશકર્તા દ્વારા અવાજ સાથે ઓવરલોડિંગ કરવાનું ટાળો, જે જ્યારે પૃષ્ઠ લોડ થાય ત્યારે ઑટોપ્લે કરે છે. જો અવાજ મૌન નથી, તો વિડિઓ બતાવશો નહીં:
ફરી એક વાર, અમે આનો ઉપયોગ કરીને લાભ લઈ રહ્યાં છીએ
:not()
pseudo-class.
:root માટે Flexible Type
એક પ્રતિસાદિત લેઆઉટમાં ટાઇપ ફૉન્ટનું કદ દરેક વ્યૂપોર્ટ સાથે વ્યવસ્થિત થવું
જોઈએ. તમે ઉપયોગ કરીને વ્યૂપોર્ટની ઊંચાઈ અને પહોળાઈના આધારે ફોન્ટ કદની
ગણતરી કરી શકો છો :root:
હવે તમે આ ઉપયોગ શ root em દ્વારા ગણવામાં આવેલ કિંમત પર આધારિત
એકમ :root:
font-size on ફોર્મ તત્વો માટે a બેટર મોબાઇલ અનુભવ
મોબાઇલ બ્રાઉઝર્સને ટાળવા માટે (iOS Safari, et al.) થી ઝુમિંગ HTML
ફોર્મ એલિમેન્ટ્સ પર જ્યારે એક <select> ડ્રોપ ડાઉન ટેપ
થયેલ છે, ઉમેરો font-size to the selector rule:
:dancer:
પોઇન્ટર ઇવેન્ટ્સ તમને સ્પષ્ટ કરવા માટે પરવાનગી આપે છે કે માઉસ કેવી રીતે તૃપ્તિ સાથે સંપર્ક કરે છે. બટનો પર ડિફૉલ્ટ પોઇન્ટર ઇવેન્ટને અક્ષમ કરવા માટે, ઉદાહરણ તરીકે:
તે સરળ છે.
display: none તરીકે વપરાયેલ લાઇન બ્રેક્સ પર સેટ કરો
હેરી રોબર્ટ્સે નિર્દેશ કર્યો, આ સીએમએસ વપરાશકર્તાઓને અંતર માટે વધારાના લાઇન બ્રેકનો ઉપયોગ કરવાથી અટકાવી શકે છે:
વર્તમાન આવૃત્તિઓ of Chrome, Firefox, Safari, Opera, Edge, અને IE11.